[Lighttpd] w chroot z obsługą PHP i MySQL

Kategoria: FAQ, etykiety: bazy danych, lighttpd

Dodany: 2010-09-28 15:27 (zmodyfikowany: 2011-04-17 23:29)
Przez: life

Wyświetleń: 10901

Opis powstał w oparciu o informacje znajdujące się na stronie: http://www.cyberciti.biz

Rozwiązanie to testowałem w Debian 5 (Lenny) wersja 32 bit.

Zakładam że masz już zainstalowanego Lighttpd oraz PHP oraz MySQL jeśli nie to instalujemy: PHP z Lighttpd działa w trybie Fast-CGI tak więc musiamy zainstalować pakiet php5-cgi

# apt-get install lighttpd php5-cgi php5-mysql mysql-server

Teraz przystąpimy do przygotowania środowiska w którym będą działać usługi.

Zakładamy katalog /chroot:

# mkdir /chroot

Nasz chroot powinien mieć niezbędną struturę i system katalogów normalnego systemu, dlatego też zakładamy następujące podkatalogi i uprawnienia dla nich:

# mkdir /chroot/tmp/
# chmod 1777 /chroot/tmp/
# mkdir /chroot/etc

Katalog w którym będziemy trzymać logi Lighttpd:

# mkdir -p /chroot/var/log/lighttpd

Lighttpd domyślnie działa na uprawnieniach użytkownika www-data dlatego też zmieniamy właściciela katalogu w którym będziemy trzymać logi:

# chown www-data:www-data /chroot/var/log/lighttpd

Utworzymy katalogi w których Lighttpd trzyma cache:

# mkdir -p /chroot/var/tmp/lighttpd/cache/compress/
# chown www-data:www-data /chroot/var/tmp/lighttpd/cache/compress/

Oraz katalog do którego uploadowane są pliki:

# mkdir -p /chroot/var/cache/lighttpd/uploads
# chown www-data:www-data /chroot/var/cache/lighttpd/uploads

Tworzymy katalog domowy użytkownika w którym będziemy trzymać stronę:

# mkdir -p /chroot/home/lighttpd
# chown www-data:www-data /chroot/home/lighttpd
# chmod 0700 /chroot/home/lighttpd

Przy tworzeniu środowiska chroot przydatny jest skrypt l2chroot, który automatyzuje kopiowanie plików i bibliotek do nowego środowiska.

#!/bin/bash
BASE="/webroot"

if [ $# -eq 0 ]; then
  echo "Syntax : $0 /path/to/executable"
  echo "Example: $0 /usr/bin/php5-cgi"
  exit 1
fi

[ ! $BASE ] && mkdir -p $BASE || : 

# iggy ld-linux* file as it is not shared one
FILES="$(ldd $1 | awk '{ print $3 }' |egrep -v ^'\(')"

echo "Copying shared files/libs to $BASE..."
for i in $FILES
do
  d="$(dirname $i)"
  [ ! -d $BASE$d ] && mkdir -p $BASE$d || :
  /bin/cp $i $BASE$d
done

# copy /lib/ld-linux* or /lib64/ld-linux* to $BASE/$sldlsubdir
# get ld-linux full file location
sldl="$(ldd $1 | grep 'ld-linux' | awk '{ print $1}')"
# now get sub-dir
sldlsubdir="$(dirname $sldl)"

if [ ! -f $BASE$sldl ];
then
  echo "Copying $sldl $BASE$sldlsubdir..."
  /bin/cp $sldl $BASE$sldlsubdir
else
  :
fi

Można go pobrać tu l2chroot.

Skrypt zapisujemy na dysku i nadajemy mu uprawnienia do wykonywania:

# wget http://www.cyberciti.biz/files/lighttpd/l2chroot.txt
# cp l2chroot.txt /bin/l2chroot
# chmod +x /bin/l2chroot

Teraz potrzebujemy umieścić w chroot PHP wraz z modułami których będziemy potrzebować. Zaczniemy od utworzenia katalogów w których przechowywane są binaria oraz biblioteki:

# mkdir -p /chroot/usr/bin
# cp /usr/bin/php5-cgi /chroot/usr/bin/
# cp /usr/bin/php5 /chroot/usr/bin/

Kolejnym etapem jest przekopiowanie plików konfiguracyjnych (wraz z uprawnieniami) dla PHP:

# cd /chroot/etc/
# cp -avr /etc/php5 .

Potrzebujemy jeszcze skopiować inne pliki konfiguracyjne z katalogu /etc

# cp /etc/hosts /chroot/etc/
# cp /etc/nsswitch.conf /chroot/etc/
# cp /etc/resolv.conf /chroot/etc/
# cp /etc/services /chroot/etc/
# cp /etc/localtime /chroot/etc/

Przy pomocy skryptu l2chroot kopiujemy pliki binarne i biblioteki dl PHP:

# /bin/l2chroot /usr/bin/php5-cgi
# /bin/l2chroot /usr/bin/php-cgi

Do poprawnego działana chroot potrzebujemy jeszcze biblioteki ld-linux.so.2 :

# cp /lib/ld-linux.so.2 /chroot/lib

Teraz zabierzemy się za moduły dla PHP, które również umieścimy w chroot. Zaczniemy od sprawdzenia gdzie pliki się znajdują na dysku:

# dpkg -L php5-mysql

/.
/usr
/usr/share
/usr/share/doc
/usr/lib
/usr/lib/php5
/usr/lib/php5/20060613+lfs
/usr/lib/php5/20060613+lfs/mysql.so
/usr/lib/php5/20060613+lfs/mysqli.so
/usr/lib/php5/20060613+lfs/pdo_mysql.so
/etc
/etc/php5
/etc/php5/conf.d
/etc/php5/conf.d/mysql.ini
/etc/php5/conf.d/mysqli.ini
/etc/php5/conf.d/pdo_mysql.ini
/usr/share/doc/php5-mysql

Nas interesuja następujące linie:

/usr/lib/php5/20060613+lfs/mysql.so
/usr/lib/php5/20060613+lfs/mysqli.so
/usr/lib/php5/20060613+lfs/pdo_mysql.so

Są to ścieżki do plików z modułami do sterownika bazy danych MySQL.

Musimy założyć katalog dla modułów a następnie skopiować je:

# mkdir -p /chroot/usr/lib/php4/20050606
# cp /usr/lib/php5/20060613+lfs/mysql.so /chroot/usr/lib/php5/20060613+lfs/
# cp /usr/lib/php5/20060613+lfs/mysqli.so /chroot/usr/lib/php5/20060613+lfs/
# cp /usr/lib/php5/20060613+lfs/pdo_mysql.so /chroot/usr/lib/php5/20060613+lfs/

Przy pomocy skryptu l2chroot kopiujemy potrzebne biblioteki:

# /bin/l2chroot /usr/lib/php5/20060613+lfs/mysql.so
# /bin/l2chroot /usr/lib/php5/20060613+lfs/mysqli.so
# /bin/l2chroot /usr/lib/php5/20060613+lfs/pdo_mysql.so

Powyższe czynności należy powtórzyć dla innych modułów jakich używamy jak GD, xcache itp.

Teraz przejdziemy do konfiguracji Lighttpd z obsługą PHP. Posłuży nam do tego skrypt lighty-enable-mod, dostarczany wraz z lighttpd.

# lighty-enable-mod fastcgi

Pozostaje jeszcze edycja pliku konfiguracyjnego Lighttpd (/etc/lighttpd/lighttpd.conf ). Otwieramy w naszym ulubionym edytorze tekstu i zmieniamy (edytujemy) linie:

server.chroot  = "/chroot"

Domyślnie jest za komentowana znakiem „#”.

server.document-root  = "/home/lighttpd/"

Zanim zrestartujemy Lighttpd musimy wykonać jeszcze jedną czynność. Połączenie z bazą danych MySQL poprzez moduł mysql.so lub mysqli.so (wersja obiektowa). Powinna działać bez problemu, gorzej spraw się ma z obsługą PDO. Pomimo że komunikacja PHP – MySQL odbywa się poprzez połączenie TCP to najprawdopodobniej samo PDO używa gniazda do łącznie się z bazą danych (socket).

Domyślnie gniazdo dla MySQL znajduje się w katalogu /var/run/mysqld/mysqld.sock

Z poziomu chroot będzie ono niedostępne dlatego musimy zmienić jego pomożenie. Najpierw utworzymy katalog i zmienimy jego właściciela na mysql:

# mkdir -p /chroot/var/run/mysqld/
# chown mysql /chroot/var/run/mysqld/

Następnie edytujemy plik konfiguracyjny MySQL (/etc/mysql/my.cnf) i zmieniamy miejsce gdzie ma być zapisane gniazdo:

[client]
socket = /chroot/var/run/mysqld/mysqld.sock

[mysqld_safe]
socket = /chroot/var/run/mysqld/mysqld.sock

[mysqld]
socket = /chroot/var/run/mysqld/mysqld.sock

Debian posiada dodatkowe skrypty monitorujące pracę MySQL, musimy je powiadomić o tym, że plik gniazda zmienił swoje domyślne położenie. Edytujemy plik /etc/mysql/debian.cnf i sekcję socket ustawiamy na: socket = /chroot/var/run/mysqld/mysqld.sock

Teraz możemy zrestartować serwer bazy danych oraz lighttpd:

# /etc/init.d/mysql restart
# /etc/init.d/lighttpd restart

Nasz Lighttpd z obsługą PHP i MySQL powinien działać w środowisku chroot.

Dla sprawdzenia poprawności działania można użyć fuknkcji phpinfo() z PHP.

W katalogu /chroot/home/lighttpd tworzymy plik plik test.php i wpisujemy do niego zawartość:

<?php
phpinfo();
?>

Wchodząc na adres http://naszadresip/test.php powinniśmy zobaczyć rezultat działania funkcji phpinfo()

OSnews Wykop Blip Flaker Kciuk Śledzik Facebook Identi.ca Twitter del.icio.us Google Bookmarks